User loginNavigation |
Well?!
A public service announcement directed to the LtU editorial team:
I am extremely busy (and tired), but what's your excuse for not posting? :-) Last chance to post something cool before the holidays... By Ehud Lamm at 2005-12-20 21:52 | Admin | login or register to post comments | other blogs | 5740 reads
ChickenfootChickenfoot is a tool that puts a programming environment in Firefox so you can write scripts to manipulate web pages and automate web browsing. In Chickenfoot, scripts are written in a superset of Javascript that includes special functions specific to web tasks. Chickenfoot is similar to Greasemonkey, but tries to provide a higher level abstraction of web pages, more appropriate for end-user programming. Take a look at the examples and decide for yourself. G-Men Called on W-Hats for WMVDOne of the cool things about Second Life is that players can create new kinds of objects, by writing small programs in a special scripting language to describe how the objects should behave, and then launching objects into the world. A highly amusing story this is. I guess the correct term for this kind of thing is The law of unintended DSL consequences. Please share similar stories, if you got them. Revisiting AWKI was dusting off my old copy of "The AWK Programming Language" by Aho, Weinberger and Kernighan (IMHO, one of the best programming books ever written) and decided to see what was being done with AWK these days. A very interesting networking extension has been added to gawk called Gawkinet. What is particularly interesting is how they managed to add networking capabilities to the language by introducing one new operator "|&" and treating network addresses like files. Leading to examples like:
BEGIN {
"/inet/tcp/0/localhost/daytime" |& getline
print $0
close("/inet/tcp/0/localhost/daytime")
}
Interesting... Countering Trusting Trust through Diverse Double-CompilingHere is a very interesting article addressing a well known compiler problem. Date: Mon, 12 Dec 2005 17:03:54 -0500 From: David A. Wheeler To: bugtraq@securityfocus.com Subject: Countering Trusting Trust through Diverse Double-Compiling Everyone here should be familiar with Ken Thompson's famous "Reflections on Trusting Trust." If not, see: http://www.acm.org/classics/sep95/ The "trusting trust" attack subverts the compiler binary; if attacker succeeds, you're doomed. Well, til now. I've written a paper on an approach to counter this attack. See: "Countering Trusting Trust through Diverse Double-Compiling" http://www.acsa-admin.org/2005/abstracts/47.html Here's the abstract: "An Air Force evaluation of Multics, and Ken Thompson's famous Turing award lecture "Reflections on Trusting Trust," showed that compilers can be subverted to insert malicious Trojan horses into critical software, including themselves. If this attack goes undetected, even complete analysis of a system's source code will not find the malicious code that is running, and methods for detecting this particular attack are not widely known. This paper describes a practical technique, termed diverse double-compiling (DDC), that detects this attack and some unintended compiler defects as well. Simply recompile the purported source code twice: once with a second (trusted) compiler, and again using the result of the first compilation. If the result is bit-for-bit identical with the untrusted binary, then the source code accurately represents the binary. This technique has been mentioned informally, but its issues and ramifications have not been identified or discussed in a peer-reviewed work, nor has a public demonstration been made. This paper describes the technique, justifies it, describes how to overcome practical challenges, and demonstrates it." I think you'll find this interesting. --- David A. Wheeler The Haskell Programmer's Guide to the IO Monad --- Don't Panic
The Haskell Programmer's Guide to the IO Monad - Don't Panic. Stefan Klinger.
Why do I need a monad for IO in Haskell? The standard explanation is, that the IO monad hides the non-functional IO actions ---which do have side effects--- from the functional world of Haskell. But how does this "hiding" work, apart from having IO actions disappearing beyond the borders of my knowledge? It's hard for me to judge how successful this tutorial is going to be with beginners, but it seems well written. The target audience isn't porgrammers trying to learn about monads as a programming construct, but rather programmers that want to get a taste of theory. By Ehud Lamm at 2005-12-15 20:47 | Category Theory | Functional | 22 comments | other blogs | 63448 reads
The MetaC Language
(via Keith)
The MetaC language extends C in a 100% backward compatible way with reflective features and techniques for refactoring, reconfiguring and modifying arbitrary C source code. Therefore, the extensions provide special metadata types for working with source code information, syntactical structures for the definiton of code templates, and metafunctions to gather information about source code and refactor, modify, delete, or insert code. Polymorphic Regular Tree Types and Patterns
It will appear in POPL '06. By Jim Apple at 2005-12-14 03:16 | Functional | login or register to post comments | other blogs | 8609 reads
Djinn, a theorem prover in Haskell, for Haskell.Lennart Augustsson announced Djinn on the Haskell mailing list recently. He included this demonstration:
Don Stewart wrote a lambdabot plugin for Djinn a few hours later. 15:39:01 @djinn a -> b -> a 15:39:02 x :: a -> b -> a 15:39:02 x x1 _ = x1 15:39:11 @djinn (a -> b -> c) -> ((a,b) -> c) 15:39:11 x :: (a -> b -> c) -> (a, b) -> c 15:39:11 x x1 (v3, v4) = x1 v3 v4 15:39:27 @djinn (a -> b) -> (c -> b) -> Either a c -> b 15:39:27 x :: (a -> b) -> (c -> b) -> Either a c -> b 15:39:27 x x1 x2 x3 = case x3 of 15:39:27 Left l4 -> x1 l4 15:39:27 Right r5 -> x2 r5 15:40:06 @djinn a -> [a] -> [a] 15:40:07 x :: a -> [a] -> [a] 15:40:07 x _ x2 = x2 15:40:08 @help djinn 15:40:09 @djinn 15:40:09 Generates Haskell code from a type. Djinn has proven to be much fun on #haskell. Top N Papers 20052005 is nearly over, and as everyone knows, December is the time for compiling hugely subjective Top 5 (10, 20, 100) lists for everything under the sun. I think it would be fun to see everybody's favorite papers... Here's mine, totally off the top of my head (I'm sure I'm forgetting something essential):
(Don't worry about trying to post the "best" papers in some objective sense, just whatever excited you... Show me what I missed this year!) |
Browse archives
Active forum topics |
Recent comments
2 weeks 2 days ago
2 weeks 3 days ago
2 weeks 4 days ago
2 weeks 4 days ago
3 weeks 2 days ago
3 weeks 2 days ago
3 weeks 2 days ago
6 weeks 3 days ago
7 weeks 1 day ago
7 weeks 1 day ago